import axios from 'axios'
import store from '@/store'
import router from '@/router'
import { Toast } from 'vant'

// 设置基地址
const instance = axios.create({
  baseURL: 'http://toutiao.itheima.net/'
})
/*************************  请求拦截 *****************************/
// 所有通过instance发送的请求都会被拦截下来
instance.interceptors.request.use(
  //添加响应拦截器
  function (config) {
    // 给config加什么，那么请求时就有什么
    // 判断一下，有token才加
    if (store.state.tokenObj.token) {
      // 所以我们想给请求头加token，就加在headers里
      config.headers.Authorization = 'Bearer ' + store.state.tokenObj.token
    }
    return config
  },
  function (error) {
    // 对请求错误做些什么
    // console.log('请求出错调用的函数')
    return Promise.reject(error)
  }
)

/*************************  响应拦截 *****************************/
// 添加响应拦截器
instance.interceptors.response.use(
  function (response) {
    // 对响应数据做点什么
    return response
  },
  async function (error) {
    if (error.response.status == 401) {
      try {
        // 能进入到这里代表token有问题
        // 利用refresh_token去获取新的token  //refresh_token：刷新token
        // 这里的坑点是：不能用instance这个对象去发请求
        // 原因：instance加了请求拦截，会把我的refresh_token给覆盖掉
        // 所以这个时候用 axios 发请求，但是它没有设置基地址，那我们自己把地址写全
        let res = await axios({
          url: 'http://toutiao.itheima.net/v1_0/authorizations',
          method: 'put',
          headers: {
            Authorization: 'Bearer ' + store.state.tokenObj.refresh_token
          }
        })
        console.log(res)
        // 拿到最新token了，就存到vuex和本地存储里
        store.commit('saveToken', {
          token: res.data.data.token,
          refresh_token: store.state.tokenObj.refresh_token
        })
        console.dir(error)
        return await instance(error.config)
      } catch {
        // 报错了，如果这里都报错了，就证明连refresh_token都过期了
        // 那就打回登录页，让它重新登录
        router.push('/login')

        Toast.fail('登录状态已过期，请重新登录')
      }
    } else {
      // 对响应错误做点什么
      return Promise.reject(error)
    }
  }
)

// 暴露出去
export default instance
